package cn.iocoder.yudao.module.erp.service.exchange;

import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.module.erp.controller.admin.exchange.vo.order.ErpExchangeOrderCreateReqVO;
import cn.iocoder.yudao.module.erp.controller.admin.exchange.vo.order.ErpExchangeOrderPageReqVO;
import cn.iocoder.yudao.module.erp.controller.admin.exchange.vo.order.ErpExchangeOrderUpdateReqVO;
import cn.iocoder.yudao.module.erp.dal.dataobject.exchange.ErpExchangeOrderDO;
import cn.iocoder.yudao.module.erp.dal.dataobject.exchange.ErpExchangeOrderItemDO;
import jakarta.validation.Valid;
import org.springframework.stereotype.Service;
import org.springframework.validation.annotation.Validated;

import java.util.Collection;
import java.util.List;

/**
 * ERP 旧料兑换订单 Service 接口
 */
@Service
@Validated
public interface ErpExchangeOrderService {

    /**
     * 创建旧料兑换订单
     *
     * @param createReqVO 创建信息
     * @return 编号
     */
    Long createExchangeOrder(@Valid ErpExchangeOrderCreateReqVO createReqVO);

    /**
     * 更新旧料兑换订单
     *
     * @param updateReqVO 更新信息
     */
    void updateExchangeOrder(@Valid ErpExchangeOrderUpdateReqVO updateReqVO);

    /**
     * 更新旧料兑换订单的状态
     *
     * @param id     编号
     * @param status 状态
     */
    void updateExchangeOrderStatus(Long id, Integer status);

    /**
     * 删除旧料兑换订单
     *
     * @param id 编号
     */
    void deleteExchangeOrder(Long id);

    /**
     * 获得旧料兑换订单
     *
     * @param id 编号
     * @return 旧料兑换订单
     */
    ErpExchangeOrderDO getExchangeOrder(Long id);

    /**
     * 获得旧料兑换订单列表
     *
     * @param ids 编号
     * @return 旧料兑换订单列表
     */
    List<ErpExchangeOrderDO> getExchangeOrderList(Collection<Long> ids);

    /**
     * 获得旧料兑换订单分页
     *
     * @param pageReqVO 分页查询
     * @return 旧料兑换订单分页
     */
    PageResult<ErpExchangeOrderDO> getExchangeOrderPage(ErpExchangeOrderPageReqVO pageReqVO);

    /**
     * 获得旧料兑换订单项列表
     *
     * @param orderId 订单编号
     * @return 旧料兑换订单项列表
     */
    List<ErpExchangeOrderItemDO> getExchangeOrderItemListByOrderId(Long orderId);

    List<ErpExchangeOrderItemDO> getExchangeOrderItemListByOrderIds(List<Long> orderIds);

    /**
     * 审核旧料兑换订单
     *
     * @param id 订单编号
     */
    void approveExchangeOrder(Long id);
    
    /**
     * 反审核旧料兑换订单
     *
     * @param id 订单编号
     */
    void disapproveExchangeOrder(Long id);

} 